



FIG. 1



FIG. 2



FIG. 3A-1



FIG. 3A-2



FIG. 3A-3



FIG. 3A



FIG. 3B







FIG. 5B

```
SOFTWARE VFC LEVELS

LEVEL 1 - 2.4V IF OFF LOAD TEST ABOVE, WITH WARNING LEVEL 2 - 1.5V IF ON SLEEP ABOVE
LEVEL 3 - 1.2V IF ON WARNING BELOW
LEVEL 4 - 1.1V IF ON STOP BELOW

HARDWARE TRIP FROM SLEEP IS BETWEEN L2-L3
```



FIG. 6

```
SOFTWARE VFC LEVELS

LEVEL 1 - 2.4V IF OFF LOAD TEST ABOVE, WITH WARNING LEVEL 2 - 1.5V IF ON SLEEP ABOVE LEVEL 3 - 1.2V IF ON WARNING BELOW LEVEL 4 - 1.1V IF ON STOP BELOW

HARDWARE TRIP FROM SLEEP IS BETWEEN L2-L3
```



FIG. 7A

FIG. 7B

| MAIN:    | reti<br>; Main Program start                                                        | ; ADC                                                                                                               | ; ADC Conversion handler                                                                                 |
|----------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
|          | read adc Ch for SVco<br>ldi<br>ldi<br>rcall                                         | base<br>ZH, SVCC<br>ZL,VCCLOWN<br>ADCRUN                                                                            | ; set chanel<br>; data store pointer<br>; call ACD Converter                                             |
|          | read adc ch for SVF0<br>ldi<br>Idi<br>rcall<br>;ldi<br>;ldi<br>;ldi<br>;ldi<br>;cbi | ZH, SVFC<br>ZL,VRCBAN<br>ADCRUN<br>VFCBAHIGH,\$O3<br>VFCBALOW,\$5e<br>VFCLAHIGH,\$02<br>VFCLALOW,\$ff<br>ddrB,onnot | ; set chanel<br>; data store pointer<br>; call ACD Converter<br>; ••• test for VFC<br>; ••• test for VFC |
| MAIN010: | ; test OFF/ON<br>sbic<br>rjmp                                                       | PINB,ONNOT<br>MAIN100                                                                                               | ; read ON pin                                                                                            |
| MAIN020: | ; test vfc for level 3<br>cpi<br>Idi<br>cpc<br>brsh                                 | VFCBALOW,low(LEV<br>TEMP,high(LEVEL3)<br>VFCBAHIGH,TEMP<br>MAIN060                                                  | EL3) ; the value is equ or high                                                                          |
| MAIN030: | rcall                                                                               | FLASH                                                                                                               | ; do flash                                                                                               |
| MAIN040: | ; test vfc for level 4<br>cpi<br>ldi<br>cpc<br>brsh                                 | VFCBALOW,low(LEV<br>TEMP,high(LEVEL4)<br>VFCBAHIGH,TEMP<br>MAIN                                                     | EL4) ; the value is equ or high, loop to                                                                 |
| main     | ; rjmp                                                                              | MAIN050                                                                                                             | ; the value is low fall or jump                                                                          |
| MAIN050: | ; Stop the converter<br>sbi<br>rjmp                                                 | PORTB,ONNOT<br>MAIN                                                                                                 | ; Stop Converter and test led<br>; loop to main                                                          |
| MAIN060: | ; test vfc for level 2<br>cpi<br>Idi<br>cpc<br>brsh<br>rjmp                         | VFCBALOW.low(LE\<br>Temp,high(LEVEL2)<br>VFCBAHIGH, TEMP<br>MAIN200<br>MAIN                                         | /EL2)<br>; the value is equ or high<br>; the value is low fall or jump                                   |
| MAIN100: | ; do flashe<br>rcall                                                                | FLASH                                                                                                               | ; do flash                                                                                               |
| MAIN110: | ; test vfc for level 1<br>cpi<br>ldi<br>cpc<br>brsh<br>; rjmp                       | VFCBALOW,low(LE'<br>TEMP,high(LEVEL1)<br>VFCBAHIGH,TEMP<br>MAIN140<br>MAIN120                                       | /EL1) ; the value is equ or high ; the value is low fall or jump                                         |
| MAIN120: | ; test vfc for level 3<br>cpi VFCBAL<br>ldi TEMP,hic<br>cpc VFCBAH                  | OW, low(LEVEL3)<br>h(LEVEL3)<br>IGH,TEMP                                                                            | FIG. 70                                                                                                  |

|                        | brsh                                           | MAIN                                         | ; the value is equ or high                        |
|------------------------|------------------------------------------------|----------------------------------------------|---------------------------------------------------|
|                        | ; rjmp                                         | MAIN130                                      | ; the value is low fall or jump                   |
| MAIN130:               | ; test Flasher for stop<br>cpi<br>breq<br>rjmp | eg<br>Flashhigh, Stope<br>Main200<br>Main    | D<br>; we need to sleep<br>; keep logging         |
| MAIN140:               | ; do load test<br>rcall                        | LOADTEST                                     | ; test the load                                   |
| MAIN150:               | ; Test for Load OK<br>tst<br>breq              | LOADOK<br>MAIN                               | ; go to main                                      |
| MAIN160:               | ; start the converter<br>cbi<br>ctr<br>ctr     | PORTB, ONNOT<br>FLASHLOW<br>FLASHHIGH        | ; Start Converter<br>; Stop Flashing              |
|                        | rjmp                                           | MAIN                                         | ; keep looping                                    |
| MAIN200:               | ; enter sleep mode<br>cbi<br>clr<br>clr        | ADCSR, ADEN<br>TICA<br>TICB                  | ; Power down the ADC                              |
|                        | idi<br>out                                     | TEMP, 0<br>TIMSK, TEMP                       | ; stop timer int                                  |
|                        | ldi<br>out                                     | TEMP, MCUCRSET<br>MCUCR, TEMP                | ; set for idel                                    |
|                        | ; may have to stop tir<br>;sbi                 | mers adc intrrupts<br>ddrb, led              | ,******                                           |
|                        | sleep<br>;cbi                                  | ; wate COMPARE<br>ddrb, led                  | , *****<br>,                                      |
| MAIN210:               | ; nop<br>; nop<br>; rjmp                       | MAIN210                                      | ; we will wate to hear for a low level 2          |
| transet                | ldi<br>out                                     | TEMP, TIMSKSET<br>TIMSK, TEMP                | ; Enable timer int                                |
|                        | sbi<br>rjmp                                    | ADSCR, ADEN<br>MAIN                          | ; Power up the ADC<br>; back to looping           |
| ; Place init code hear | 01 - 0 1                                       |                                              |                                                   |
| RESET:                 | ; Clear Requesters<br>dr<br>Idi<br>st          | r0<br>z1,29<br>z,r0                          | ; Clear a master<br>; Point to req r29<br>; Clear |
| RESET01:               | dec z1<br>brne                                 | ; set for next<br>RESET01                    | ; loop                                            |
|                        | Setup the ADC<br>Idi<br>out<br>sbi             | TEMP, ADCSRSET<br>ADCSR, TEMP<br>ADCSR, ADEN | ; Power up the ADC                                |
|                        | : Setup the comparit<br>Idi<br>out             | or<br>TEMP, ACSRSET<br>ACSR, TEMP            |                                                   |
|                        | Setup timer 0 for d                            | iv 64<br>TEMP, TCCR0SET                      | FIG. 7D                                           |

,

|                                                                     | out                                                           | TCCR0, TEMP                                                                                   |                                                  |
|---------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------|
|                                                                     | : Setup Timer 1 for 1<br>ldi<br>out<br>ldi<br>out             | .ms int<br>TRMP, TCCR1SET<br>TCCR1, TEMP<br>TEMP, OCR1ASET<br>OCR1A, TEMP                     |                                                  |
|                                                                     | : Setup Port B<br>ldi<br>out<br>ldi<br>out                    | TEMP, DDRBSET<br>DDRB, TEMP<br>TEMP, PORTBSET<br>PORTB, TEMP                                  | ; Data direction                                 |
|                                                                     | ; ldi                                                         | ticb, 100                                                                                     |                                                  |
|                                                                     | : Enable Interrupts<br>Idi<br>out<br>Idi<br>out<br>Idi<br>out | TEMP, TIMSKSET<br>TIMSK, TEMP<br>TEMP, GIMSKSET<br>GIMSK, TEMP<br>TEMP, SREGSET<br>SREG, TEMP | ; Enable timer int<br>; Set the mask<br>; Enable |
|                                                                     | ; Setup sleep<br>ldi<br>out                                   | TEMP, MCUCRSET<br>MCUCR, TEMP                                                                 |                                                  |
|                                                                     | ; setup start delays<br>İdi<br>İdi                            | TICA, FLASHDEL<br>TICB, LOADDEL                                                               | ; flash start delay<br>; load start delay        |
| RESETEND:                                                           | rjmp                                                          | MAIN                                                                                          |                                                  |
| ; This ISR will dec the Time regesters tica and ticb to 0 TIM1_CMP: |                                                               |                                                                                               |                                                  |
| Tic01:                                                              | in<br>tst<br>breq<br>dec<br>tst<br>breq                       | TEMPF, SREG<br>tica<br>tic01<br>tica<br>ticb<br>tic02                                         | ; save status                                    |
| Tic02:                                                              | dec<br>out<br>reti                                            | ticb<br>SREG, TEMPF                                                                           | ; Restor status                                  |
| ; This ISR will handal end of time 0 overflows TIMO_OVF:            | ; we ret at vector<br>reti                                    |                                                                                               |                                                  |
| ; This ISR will handal changes in FC Volts it will retern ANA_COMP: | to last place                                                 |                                                                                               |                                                  |
| ANA_COMIT.                                                          | •                                                             | fix timer for fast service i                                                                  | n main                                           |
| ADC:                                                                | reti<br>reti                                                  |                                                                                               |                                                  |
| EE_RDY                                                              | reti                                                          |                                                                                               | ; This ISR may be used                           |
| later<br>TIM1_OVF:                                                  | reti                                                          |                                                                                               | ; This ISR will be                               |
| disabled                                                            |                                                               |                                                                                               | FIG 7                                            |

FIG. 7E

| Rutine to manage low fuel flasher The two byte flash count also acts as a run flag as follow Low byte not 0, the counter is active Low byte equ 0, the high byte has | vs:<br>we and flashing<br>meaning as follws:<br>0 = clear to start flash<br>1 = flash time comple! | ing<br>t                                                    |                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| 1                                                                                                                                                                    | any other go to sleep                                                                              |                                                             |                                                                                             |
| FLASH:                                                                                                                                                               | ; Start Flasher                                                                                    |                                                             |                                                                                             |
|                                                                                                                                                                      | tst<br>brne<br>Idi                                                                                 | TICA<br>FLASHEND<br>TICA, TICFLASH                          | test for time to run<br>must be zero th run<br>reset the timer                              |
|                                                                                                                                                                      | tst<br>bme<br>tst<br>brne                                                                          | Flashlow<br>Flash10<br>FlashHigh<br>Flashend                | ; test for need<br>; go to flashing<br>; test for stoped<br>; the flasher is stoped         |
|                                                                                                                                                                      | ; Start the flasher<br>Idi<br>Idi                                                                  | FLASHLOW, LOW(FL<br>FLASHHIGH, HIGH(F                       |                                                                                             |
| FLASH10:                                                                                                                                                             | ; flash the LED<br>cbi                                                                             | PORTB, LED                                                  | ; LED lamp on                                                                               |
|                                                                                                                                                                      | ; time the flash<br>Idi<br>rcall                                                                   | TEMP, TIME40m<br>WATE ; I                                   | ; load time value<br>wate for time                                                          |
|                                                                                                                                                                      | ;out<br>;ldi<br>;out<br>;sleep                                                                     | TCNT0, TEMP<br>TEMP, MCUCRSET<br>MCUCR, TEMP                | ; set for idel                                                                              |
|                                                                                                                                                                      | : stop the flash<br>sbj                                                                            | PORTB, LED                                                  | ; LED lamp off                                                                              |
|                                                                                                                                                                      | ; count the flashes inc                                                                            | FLASHLOW<br>FLASHEND                                        | ; Adjust Count                                                                              |
|                                                                                                                                                                      | brne<br>inc<br>inc                                                                                 | FLASHLOW<br>FLASHHIGH                                       | ; Can not be zero<br>; Adjust high byte                                                     |
|                                                                                                                                                                      | brne<br>cIr<br>inc                                                                                 | FLASHEND<br>FLASHLOW<br>FLASHHIGH                           | ; Flash time is over stop flash ; Set stoped                                                |
| FLASHEND:                                                                                                                                                            | ret                                                                                                |                                                             |                                                                                             |
| ADCRUN:                                                                                                                                                              | rutine for ADC<br>ldi<br>add                                                                       | TEMP, ADMUXSET<br>TEMP ZH<br>ADMUX, TEMP                    |                                                                                             |
|                                                                                                                                                                      | out<br>sbi<br>;ldi<br>:aut                                                                         | ADMUX, 1EMP<br>ADCSR, ADSC<br>TEMP, MCUCRADO<br>MCUCR, TEMP | ; Set adc chanel<br>; Start the ADC Conversion<br>; set for ADC                             |
| ADCRUN01:                                                                                                                                                            | ;out<br>;sleep<br>sbis<br>rjmp<br>in<br>st                                                         | ADCSR, ADIF<br>ADCRUN01<br>TEMP, ADCL<br>Z, TEMP<br>ZL      | ; wate for adc end<br>; Test for end of conversion<br>; Loop till end<br>; Get the resulats |
| FIG. 7F                                                                                                                                                              | inc<br>in<br>st                                                                                    | ZL<br>TEMP, ADCH<br>Z, TEMP                                 | ; Get the resulats                                                                          |

| LOADTEST:                                      | ret<br>clr<br>; work load test                     | LOADOK                                                                                | ; make load not OK                                                                    |  |
|------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
|                                                | tst<br>bme<br>Idi                                  | TICB<br>LOADTESTEND<br>TICB, TICLOAD                                                  | ; test for time to run<br>; must be zero th run<br>; reset the timer                  |  |
|                                                | sbi                                                | DDRB, LOAD                                                                            | ; start Load by seting output                                                         |  |
|                                                | time the load<br>Idi<br>rcall                      | TEMP, TIME20m<br>WATE                                                                 | ; load timer to start                                                                 |  |
|                                                | ;out<br>;Idi<br>;out<br>;sleep                     | TCNTO, TEMP<br>TEMP, MCUCRSET<br>MCUCR, TEMP<br>; wate for time                       | ; set for idel                                                                        |  |
|                                                | read adc ch for SVFC                               |                                                                                       |                                                                                       |  |
|                                                | ldi<br>Idi<br>rcall                                | ZH, SVFC<br>ZL, VFCLAN<br>ADCRUN                                                      | ; set chanel<br>; data store pointer                                                  |  |
|                                                | cbi                                                | DDRB, LOAD                                                                            | ; stop Load by try stating                                                            |  |
|                                                | ; find load dif<br>mov<br>mov<br>sub<br>sbc        | VFCDIFHIGH, VFCE                                                                      | CDIFLOW, VFCBALOW<br>CDIFHIGH, VFCBAHIGH<br>CDIFLOW, VFCLALOW<br>CDIFHIGH, VFCLAGHIGH |  |
|                                                | ; test dif<br>cpi<br>Idi<br>cpc<br>brsh            | VFCDIFLOW, low(loaddelta)<br>TEMP, high(loaddelta)<br>VFCDIFHIGH, TEMP<br>LOADTESTEND |                                                                                       |  |
| LOAD10:                                        | doc                                                | LOADOK                                                                                | ; set load OK \$FF                                                                    |  |
| LOADTESTEND:                                   | ret                                                |                                                                                       |                                                                                       |  |
| ; runtine to use timer 0 for wating, Temp time |                                                    |                                                                                       |                                                                                       |  |
| WATE:                                          |                                                    |                                                                                       |                                                                                       |  |
| YVAIL.                                         | out<br>Idi<br>out<br>sleep<br>ret                  | TCNTO, TEMP<br>TEMP, MCUCRSET<br>MCUCR, TEMP<br>; wate for time                       | ; set for idel                                                                        |  |
| Trace:                                         | ; A lamp blinb rutin<br>sbic<br>rimp<br>sbi<br>cbi | e for testing<br>PINb, led<br>Tracel<br>PORTb, led<br>PORTb, onnot<br>Traceend        |                                                                                       |  |
| Tracel:                                        | rjmp<br>cbi                                        | PORTb, led                                                                            |                                                                                       |  |
| Traceend:                                      | sbi<br>ret                                         | PORTb, onnot                                                                          |                                                                                       |  |
| EXIT                                           |                                                    |                                                                                       |                                                                                       |  |
|                                                |                                                    |                                                                                       |                                                                                       |  |

FIG. 7G



FIG. 8A



FIG. 8B



FIG. 8C



FIG. 8D













FIG. 18



FIG. 19



FIG. 20



FIG. 21







FIG. 24



FIG. 25



FIG. 26



FIG. 27



FIG. 28



FIG. 29